

# EE4620/6620, CEG4324/6324 Digital Integrated Circuit Design with PLDs and FPGAs

Lab 0 (Spring 2024)

# Xilinx Vivado Simulation Environment Using VHDL and Testbench

#### A. Introduction

The main objective of this lab is for you to become familiar with the Xilinx Vivado simulation environment. Read all directions carefully. You will follow the Vivado tutorial to create a VHDL project in Xilinx Vivado and functionally verify and validate your design through Vivado simulation environment. Read through all of the steps before you begin the lab.

### B. Create a Project

1. In this lab, the VHDL design code (comb\_function.vhd) describes a combinational circuit with three inputs, A, B, and C, and two outputs, F and G.

| <br>A | В | C | F    | G |
|-------|---|---|------|---|
| <br>  |   |   | <br> |   |
| <br>U | U | U | 0    | U |
| <br>0 | 0 | 1 | 1    | 1 |
| <br>0 | 1 | 0 | 1    | 1 |
| <br>0 | 1 | 1 | 0    | 1 |
| <br>1 | 0 | 0 | 0    | 1 |
| <br>1 | 0 | 1 | 1    | 0 |
| <br>1 | 1 | 0 | 1    | 1 |
| <br>1 | 1 | 1 | 0    | 0 |

Note the synthesis off and on comment lines. These lines turn the circuit synthesizer OFF and ON, so it skips the code in between. The timing simulation information is not synthesized, only for simulation purposes. For this example circuit, we use delays of

1 ns for inverter

2 ns for 2-input logic gates such as AND, NAND, OR, NOR

3 ns for 3-input logic gates such as AND, NAND, OR, NOR.

4 ns for 4-input logic gates such as AND, NAND, OR, NOR.

- 2. Simulate the design code from part 1. Look at the test bench file, tb\_comb\_function.vhd. In this file, you see the test bench code for simulating a simple three input combinational function. It exhaustively simulates the functionality of the circuit. It uses a generic set at the beginning of the file, i.e., WPD (Worst Propagation Delay) = 5 ns, to set the amount of time that each vector is applied to the circuit. Follow the Vivado tutorial to simulate the design (comb\_function.vhd) using the test bench file (tb\_comb\_function.vhd). Verify your simulation waveform if there are any simulation errors. Note: It takes time to simulate circuits with more inputs exhaustively.
- Generate bitstream, program the ZedBoard, and load your design onto the FPGA board. Follow TA's
  instruction to verify your FPGA design by switching inputs and demonstrating your outputs from onboard OLED.

## C. Report [50 pts] (Submitted to your Lab Pilot <u>Dropbox</u> by 11:30 pm, Sunday, Jan. 28, 2024)

- 1. [10 pts] Set WPD = 5 ns in the tb\_comb\_function.vhd. Simulate the comb\_function.vhd design. Mark on your simulation waveform if there are any simulation errors. Explain why these errors are.
- 2. [10 pts] Set WPD = 6 ns in the tb\_comb\_function.vhd. Simulate the comb\_function.vhd design. Mark on your simulation waveform if there are any simulation errors. Explain why these errors are.
- 3. [30 pts] Consider a new truth table

| <br>A | В | C |   | F | G |
|-------|---|---|---|---|---|
| <br>  |   |   |   |   |   |
| <br>0 | 0 | 0 |   | 1 | 0 |
| <br>0 | 0 | 1 | Ì | 0 | 1 |
| <br>0 | 1 | 0 |   | 0 | 1 |
| <br>0 | 1 | 1 |   | 1 | 0 |
| <br>1 | 0 | 0 |   | 0 | 1 |
| <br>1 | 0 | 1 |   | 1 | 1 |
| <br>1 | 1 | 0 |   | 0 | 0 |
| <br>1 | 1 | 1 |   | 1 | 1 |

Write your new VHDL design code (*new\_comb\_function.vhd*) describing a combinational circuit with three inputs, A, B, and C, and two outputs, F and G. Use K-map to optimize your design.

- Set WPD = 6 ns in the tb\_comb\_function.vhd. Simulate the *new\_comb\_function.vhd* design. Mark on your simulation waveform if there are any simulation errors. Explain why these errors are.
- Set WPD = 7 ns in the tb\_comb\_function.vhd. Simulate the *new\_comb\_function.vhd* design. Mark on your simulation waveform if there are any simulation errors. Explain why these errors are.
- Submit your VHDL design code and simulation waveforms.